//给定一个二叉搜索树 root 和一个目标结果 k，如果 BST 中存在两个元素且它们的和等于给定的目标结果，则返回 true。 
//
// 
//
// 示例 1： 
// 
// 
//输入: root = [5,3,6,2,4,null,7], k = 9
//输出: true
// 
//
// 示例 2： 
// 
// 
//输入: root = [5,3,6,2,4,null,7], k = 28
//输出: false
// 
//
// 
//
// 提示: 
//
// 
// 二叉树的节点个数的范围是 [1, 10⁴]. 
// -10⁴ <= Node.val <= 10⁴ 
// root 为二叉搜索树 
// -10⁵ <= k <= 10⁵ 
// 
//
// Related Topics 树 深度优先搜索 广度优先搜索 二叉搜索树 哈希表 双指针 二叉树 👍 422 👎 0


package leetcode.editor.cn;

import java.util.*;

/**
 * 两数之和 IV - 输入 BST
 * @date 2022-08-22 10:22:26
 */
class P653_TwoSumIvInputIsABst{
	 public static void main(String[] args) {
	 	 //测试代码
	 	 Solution solution = new P653_TwoSumIvInputIsABst().new Solution();
	 }
	 
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
	HashSet<Integer> hashSet = new HashSet<>();
    public boolean findTarget(TreeNode root, int k) {
		return preorder(root,k);
    }
	public boolean preorder(TreeNode root,int k){
		if(root == null){
			return false;
		}
		if(hashSet.contains(k- root.val)){
			return true;
		}
		hashSet.add(root.val);
		return preorder(root.left,k) || preorder(root.right,k);
	}
}
//leetcode submit region end(Prohibit modification and deletion)

}
